草庐IT

Android APP开机启动

全部标签

go - 等待 gin HTTP 服务器启动

我们正在使用gin来公开生产中的一些RESTAPI。现在我必须在HTTP服务器启动后做一些事情。我对channel不是很熟悉,但下面给出的代码是我想要做的。startHTTPRouter()启动HTTP服务后,我想向main()发送一个信号。基于这个信号,我想做一些其他的事情。请让我知道我在下面给出的代码中做错了什么。funcstartHTTPRouter(routerChannelchanbool){router:=gin.New()//ManyRESTAPIroutesdefinitionsrouter.Run("")routerChannel 最佳答案

go - 如何在 Go 中创建一个通用的 GRPC 服务器启动函数

我正在尝试抽象GRPC服务器的启动原主函数如下:funcmain(){lis,err:=net.Listen("tcp",port)iferr!=nil{log.Fatalf("failedtolisten:%v",err)}s:=grpc.NewServer()pb.RegisterCollectionServer(s,&server.Server{})//RegisterreflectionserviceongRPCserver.reflection.Register(s)iferr:=s.Serve(lis);err!=nil{log.Fatalf("failedtoserve:

google-app-engine - 为什么 gcloud 组件更新命令总是显示重新启动命令

当我想将我的Go应用程序部署到AppEngine时,我发现我必须安装app-engine-go。而且还说是在新窗口安装,没有弹出窗口。https://github.com/ChihchengHsieh/ProblemsScreenShot/blob/master/image-2.pngC:\go-work\src\orderFunc>gcloudappdeployThecomponent[app-engine-go]isrequiredforstagingthisapplication.Restartingcommand:$gcloudcomponentsinstallapp-engi

当使用另一个用户的凭据启动子进程时,Go 应用程序挂起

过去6个月左右,我一直在Ubuntu14.04上使用一个简单的游戏服务器管理应用程序。在最近的服务器更新和重新启动之后,应用程序将在尝试启动子进程时挂起。经过一些调试后,似乎每当我尝试使用另一个用户的凭据启动子进程(我以root身份运行)时,任何命令都会挂起。下面是一个简单的应用程序,用于演示导致挂起的原因:packagemainimport("os/exec""syscall""fmt")funcmain(){proc:=exec.Command("ls")proc.SysProcAttr=&syscall.SysProcAttr{}proc.SysProcAttr.Credenti

heroku - 如何为我的应用传递启动参数?

我想在我的应用程序中传递启动参数,这样我就可以告诉应用程序在DEV或PROD设置中加载。我如何在heroku上执行此操作? 最佳答案 首先在Heroku中声明ENV变量,即:heroku配置:设置APPMODE=PROD然后在你的应用程序中,导入os包并调用Getenv。示例:packagemainimport'os'varappmodestringfuncinit(){appmode=os.Getenv("APPMODE")//PROD}其他选项,使用标志包。示例://flagsoverflowpackagemainimport"

go - 找出谁启动了 goroutine (pprof)

在检查pprof的输出时,我可以看到goroutine的堆栈跟踪。但是我想知道是谁开始(产生?)这个goroutine,这可能吗? 最佳答案 如果您查看端点/debug/pprof/goroutine?debug=2,您会得到堆栈跟踪的稍微不同的输出:goroutine859579[running]:runtime/pprof.writeGoroutineStacks(0x176a0e0,0xc43403a340,0x178d740,0x30)/usr/local/go/src/runtime/pprof/pprof.go:585+

如果在其他回调中启动删除,则不会调用 Go-gorm BeforeDelete 回调

我的数据库中有一个层次模型(一个团队有客户,每个客户都可以有注释)。如果团队被删除,我的目标是能够清理数据库:->删除团队->删除所有客户->删除每个客户的所有备注我的计划是通过BeforeDelete回调来完成,但是在团队回调之后,不再正确调用Customers的BeforeDelete。在数据库中,团队及其客户被删除,但客户的注释没有。也不打印日志行。您知道是否可以链接这些回调,或者是设计不执行第二个回调。packagemainimport("errors""log""github.com/jinzhu/gorm"_"github.com/jinzhu/gorm/dialects/

go - 使用 Golang 启动 D-Bus 服务

我现在正在使用适用于golang的D-BusAPI调用并启动一个systemd服务(我的只是调用一个shell脚本)。我在/usr/share/dbus-1/system-services/org.freedesktop.hello.service做了一个D-Bus服务[D-BUSService]Name=org.freedesktop.helloExec=/bin/falseUser=rootSystemdService=hello.service还有/lib/systemd/system/hello.service中的systemd服务[Unit]Description=Hello

go - 在 Go 中启动后进行守护进程

我有一个系统我需要作为守护进程运行,它是用go开发的。通常我可以通过类似systemd的东西或者甚至像'./project&'这样简单的东西来管理它,但是这个特定的项目需要在它成为守护进程之前获得一些输入——它需要一个密码待输入。此密码不能作为命令行参数提供、放置在配置文件中、在源代码中硬编码等。它必须由知道密码的人在系统启动时手动提供。在启动时,项目需要收集密码,验证一切正确,只有提供了正确的密码(通过尝试解密证书来验证),它才能真正开始作为守护进程运行。有什么方法可以让项目启动、接受来自标准输入的输入、执行任何需要的验证等,然后才成为守护进程(从标准输入等分离)?目前我可以通过启动

go - 如何检查 Cloud Pub/Sub 模拟器是否已启动并正在运行?

我有GC功能,我使用CloudPub/Sub模拟器在本地开发和测试这些功能。我希望能够从Go代码中检查CloudPub/Sub模拟器是否已启动并正在运行。如果没有,我想通知开发人员他/她应该在他/她在本地执行代码之前启动模拟器。当模拟器启动时我注意到一条线INFO:Serverstarted,listeningon8085也许我可以检查端口是否可用或类似。 最佳答案 我猜你用过这个命令:gcloudbetaemulatorspubsubstart你得到了以下输出:[pubsub]ThisistheGooglePub/Subfake.